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SECTION I 
INTRODUCTION 



1-1. PROGRAM SUMMARY 

1-2. The Hardware Multiply/Divide Test (ND41-8045) is a diagnostic program designed 
to check the ND812 hardware multiply and divide circuitry. 

NOTE 

This diagnostic applies to ND812 Central Processors serial number 236 
and up or to earlier processor equipped with the 24 X 12 divide modi- 
fication . 



1-3. PROGRAM AREA 



1-4. This program may reside in any Memory Field octal locations 0200 through 0425. 
1-5. STARTING ADDRESS 



1-6. The starting address of this program is 0200Q. 
1-7. EQUIPMENT CONFIGURATION 



1-8. Minimum equipment required for proper operation of this program includes: 

a. ND8I2 Central Processor equipped with the 24 X 12 divide modification 
(88-0397) 

b. ASR33 Teletype and interface (86-0085 and 88-0481). 
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SECTION II 
PROGRAM DESCRIPTION 



2-1. MAIN ROUTINE 

2-2. The Hardware Multiply/Divide Diagnostic performs incrementing multiplication and 
division operation using three 12-bit values, A, B, and C for the equation: 

(A*B) + C 

q = A + C (or as the program defines, A remainder C) 



where, 



A and B are initially set to 1 . 
C is initially set to J0. 



■ 2-3. Value A is incremented by one from 1 to 4095. When A reaches the value 4095, 
B is incremented to two and A is set to one. A will again be incremented to 4095, B 
incremented to three and A set to one. This sequence is followed until value B equals 
4095 at which time C is incremented to one and the entire sequence re-initialized. Thus: 

A is incremented from one to 4095 for each increment of B 
and B is incremented 4095 times for each increment of C. 

2-4 Printout provided by this program is in two forms. The first states the values used 
when an erroneous answer was computed. 

A X B = Z + C/B = X R Y 

where, 

A, B, C,X, and Y are 12-bit numbers 

Z is the 24-bit product. 

R indicates remainder (X remainder Y) 

and 
X should = A 
Y should = B 



2-5. The second printout will be automatically provided each time value C is incremented 
(approximately every 15 minutes) and contains the accumulation errors. Printout is in the 
following form: 

00000071 E 

This feature is of value when overnight testing is desired. 

2-6. Another feature is included that prevents the program from incrementing any values 
when an error condition is encountered. This allows troubleshooting of a particular set of 
values if a pattern is detected. Setting the ND812 SWITCH REGISTER Bit to "1" enables 
the feature. 
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SECTION III 
OPERATIONAL PROCEDURE 



3-1. LOADING AND INITIALIZATION PROCEDURE 

3-2, The following is a step-by-step procedure describing the program loading sequence: 

a. Load the Hardware Multiply/Divide Test (ND41-8045) into any Memory Field 
with the Binary Loader or Hardware Loader, Refer to IM41-0005 for loading procedure. 

b. Set the ND812 SWITCH REGI STER to J02#0g and depress LOAD AR key. 

c. Depress the ND812 START key. 

d. The program will start and continue to operate until the ND812 STOP key is 
depressed. 
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SECTION IV 
OPERATOR OR USER CONTROL 



4-1. GENERAL INFORMATION 

4-2. In addition to the initiation and termination procedure outlined in Section III, the 
value redundancy control is the only operator control. Value redundancy is accomplished by 
setting the ND812 SWITCH REGISTER Bitj0 to "1" and causes the program to continually 
execute the diagnostic test using the values used when an error was detected. To recover 
from the redundancy operation, set the ND812 SWITCH REGISTER Bitjtf to "J0". 
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SECTION V 
ERROR DIAGNOSTICS 



5-1. ERROR INDICATIONS 



5-2. Detection of an error causes the program to print: 
A X B = Z + C/B = X R Y 

where, 

A, B,C,X and Y are 12-bit numbers 

Z is the 24-bit product 

R indicates remainder (X remainderY) 

and 
X should = A 
Y should = B 

5-3. An accumulative error message is printed for every incrementation of value C and is 
in the following form; 

00000071 E 
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SECTION VI 
COMMAND SUMMARY 



6-1. GENERAL 



6-2. This program does nor use keyboard entry command. The only controls are the 
ND812 STOP key for termination and SWITCH REGISTER Bit for the value redundancy 
operation. 
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SECTION VII 
FLOW CHARTS 



7-1. GENERAL 

7-2. Attached pages 7-2 and 7-3 is a flow chart of the Hardware Multiply/Divide Test. 
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Figure 7-1. Hardware Multiply/Divide Flow Chart (Sheet 1 of 2) 
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SECTION Vill 
PROGRAM LISTING 



8-1. GENERAL 

8-2. Attached is a copy of the Hardware Multiply/Divide binary listing. 
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CO 



/ND41 




HARDWARE 


MULTIPLY 


-DIVID 


/BIT 


LOCKS SYSTEM 


IN SCOPE 


LOOP 






* 2 






0200 




START. 


CLR 


J 


02S i 


>5A7& 

" W W f V ? 




STJ 


MAXREM 




1 r i 4 

J. A *r 


u u y 1 w , 


CLR INC 


J 


0203 


> 5 4 7 1> 




STJ 


A 


PI 2 Pi 4 


>547 f i 




STJ 


B 


0S£5 


1*4 


L00P2 , 


CLR 


J 


0206 


>5474 




STJ 


REM 


0207 


6 434 


LOOP 1 1 


JPS 


MDTEST 


02 1 


5 pi 7 2 




LD J 


REM 


021 1 


2466 




SMJ 


MAXREM 


02 12 


(5 (2 6 




JMP 


LIMIT 


0213 






INC 


J 


02:1 4 


5 46 6 




STJ 


REM 


0215 


2464 




SMJ 


B 


8216 


6 & G 2 




JMP 


LIMIT 


02 1 7 


6 J 1 




JMP 


LOOP1 


0220 


346R 


LIMIT # 


ISZ 


A 


0221 


6114 




JMP 


L00P2 


0222 


3 4 56 




ISZ 


A 


0223 


V H V v 




ISZ 


B 


0224. 


6117 

'J 1 i f 




JMP 


L00P2 


0225 






ISZ 


MAXREM 


0226 






SET 


J 


0227 


5451 




STJ 


A 


0230 


5451 




STJ 


B 


0231 






SU8L 


1 


0232 


V *» v* »J 




STJ 


REM 


8233 


fi /1 1 !7i 
\j t 1 «y 




JPS 


MDTEST 


0234 


/ 1<J -J vy 




XCT 


X2 


0235 


*5 K S 1 




LOJ 


CNTR+i 


0236 


7 <■* 




XCT 


X3 


0237 


yi Vj *» C 




LD J 


CNTR 


0240 


7053 




XCT 


XI 


0241 


0305 




305 




0242 


6140 




JMP 


L00P3 


0243 


0000 


MDTESTi 







0244 


1010 


SCOPE,, 


LJSW 




024b* 


1506 




SIN 


J 


0246 


1410 




CLR 


FLAG 


0247 


5031. 




LD J 


A 


0250 


0510 




TWLDK 




0251 


0301 




B 





E TEST C24X12) 

AFTER FIRST ERROR 



/ SET J a 

/ SET MAXIMUM LEGAL REMAINDER * ZERO 

/ SET J 8 1 

/ As i 

/ B* 1 

/ SET J • 

/ SET REMAINDER « ZERO 

/ EXECUTE TEST SUBROUTINE 

/ CHECK FOR REM AT MAXREM LIMIT 

/ SKIP IF DIFFERENT 

/ REM LIMIT REACHED - GO TO LARGER LOOP 

/ UPDATE REM 

/ SAVE IN REM 

/ CHECK FOR REM AT B LIMIT 

/ REM LIMIT REACHED - GO TO LARGER LOOP 

/ NO LIMIT REACHED - REPEAT SMALLEST LOC 

/ A+l INTO A, OVERFLOW? 

/ NO, REPEAT MULTIPLY DIVIDE LOOP 

/ YES, SET A « 1 

/ NO, B+l INTO B, OVERFLOW? 

/ NO, CONTINUE INTERMEDIATE LOOP 

/ YES, INCREMENT MAXIMUM LEGAL REMAINDER 

/ SET J « 7777 

/ SET A » 7777 

/ SET B ■ 7777 

/ SET J « 7776 

/ SET REM 1 7776 

/ OUTPUT CR. LF. 

/ SET J ■ MSB OF COUNTER 

/ OUTPUT VALUE 

/ SET J a TO LSB OF COUNTER 

/ OUTPUT VALUE 

/ OUTPUT E FOR ERRORS 

/ DO OUTER LOOP AGAIN 

/ GENERAL MULTIPLY/DIVIDE SUBROUTINE 

/ LOAD J FROM SWITCH REGISTER 

/ IS BIT ON? 

/ NO, SET FLAG « 

/ YES, SET J * A 

/ SET K * B 
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0252 


1000 




MPY 




/ 


0253 


5026 




LDJ 


B 


/ 


8254 


1303 




EXJRKS 




/ 


0255 


0550 




TWSTK 




/ 


025 6 


0374 




KV 




/ 


0257 


5424 




STJ 


JV 


/ 


026P) 


1450 




CLR 





/ 


0261 


4421 




AD J 


REM 




0262 


1455 




SIZ CLR 







0263 


1604 




INC 


K 




0264 


10 01 




DIV 




/ 


0265 


1 405 




SIZ 


FLAG 


/ 


0266 


612? 


X4, 


JMP 


SCOPE 


/ 


0267 


54 1 & 




STJ 


A J 


/ 


0270 


0250 




TWSMK 




/ 


0271 


0302 




REM 






0272 


1442 




SKIP 






0273 


6014 




JMP 


ERR 


/ 


0274 


240 4 




SMJ 


A 


/ 


0275 


6332 




JMPP 


MDTEST 


/ 


0276 


601 1 




JMP 


ERR 


/ 


0277 


CI 


MAXREM , 







/ 


0300 


0000 


A, 







/ 


03PI 


0000 


9 , 







/ 


0302 


0000 


REM, 







/ 


0303 


0000 


JV , 







/ 


0304 


00 00 


AJi 







/ 


03W5 


P 


CNTR» 







/ 


0306 


0000 









/ 


0307 


1405 


ERR f 


SIZ 


FLAG 


/ 


0310 


6033 




JMP 


C0UNT2 


/ 


0311 


>6474 


X2* 


JPS 


CRLF 


/ 


0312 


5112 




LDJ 


A 




0313 


6 4 40 


XI , 


JPS 


OCTS 


/ 


0314 


0330 




330 






0315 


5114 




LDJ 


B 




0316 


6435 




JPS 


OCTS 


/ 


0317 


0275 




275 






0320 


50 5 4 




LDJ 


KV 




0321 


6444 


X3, 


JPS 


OCT 


/ 


0322 


5117 




LDJ 


JV 




0323 


6430 




JPS 


OCTS 




0324 


0253 




253 






0325 


5123 




LDJ 


REM 




0326 


6 4 25 




JPS 


OCTS 




0327 


0257 




257 






0330 


5127 




LDJ 


B 




0331 


6422 




JPS 


OCTS 





A i B a . THEN A.B/B 
SET J « B 

J a LSB KbMSB R*i S« ALTERED VALUE 

STORE RESULT OF MULTIPLY AT KV AND 

MSB AT KV 

LSB AT JV 

SET UP TO ADD REM 



DIVIDE K. J/R. QUOTIENT IN J REM. IN 
IS FLAG a 

NO i GO CONTINUE IN SCOPE LOOP 
STORE QUOTIENT IN AJ 
IS REMAINDER CORRECT? 



NO, ERROR $ REMAINDER SHOULD a REM 
YES, ARE A AND QUOTIENT *? 
ALL RESULTS O.K. - EXIT 
NO, ERROR THEY SHOULD BE *. 

MAXIMUM ALLOWABLE REMAINDER 
MULTIPLICAND 
MULTIPLIER AND DIVISOR 
REMAINDER 

PRODUCT OF MULTIPLICATION - LSB 
QUOTIENT OF DIVIDE A.B/B 
LSB OF COUNTER 
MSB OF COUNTER 

SKIP IF FLAG NOT SET 
NO, GO TO C0UNT2 
OUTPUT CR. LF. 

OUTPUT A 



OUTPUT B 



OUTPUT KV 
OUTPUT JV 
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0332 


0?75 




275 








0333 


5127 




LOJ 


AJ 






0334 


6417 




JPS 


OCTS 


/OUTPUT AJ 


0335 


0322 




325 








0336 


1374 




ROTD 


JK 14 






0337 


6426 




JPS 


OCT 


/ 


OUTPUT REMAINDER 


0341* 


1 1 




I JSW 




/ 


LOAD SWITCH REGISTER 


0341 


1502 




SIP 


J 






0342 


1420 




CMP 


FLAG 






0343 


3536 


C0UNT2, 


ISZ 


CNTR 


/ 


INCREMENT COUNTER . OVERFLOW? 


034 4 


1442 




SKIP 




/ 


NO 


0345 


3537 




ISZ 


CNTR+1 


/ 


YES, INCREMENT MSB OF COUNTER 


0346 


1 1.0 




LJSW 




/ 


LOAD J FROM SWITCH REGISTER 


0347 


1 5 55 6 




SIN 


J 


/ 


IS BIT ON? 


0350 


62515 




JMPI> 


ALOOPP 






3 51 


14 30 




SET 


FLAG 


/ 


YES, SET FLAG a 1 


0352 


7164 




XCT 


X4 


/JMP SCOPE / LOCK INTO SCOPE LOOP 


0353 


0000 


OCTS, 











0354 


64 1 1 




JPS 


OCT 






0355 


5045 




LDJ 


K240 


/ 


SET J 9 240 


0356 


6435 




JPS 


TYPE 


/ 

w 


PRINT SPACE! 


0357 


5304 




LD J$ 


OCTS 






0360 


6433 




JPS 


TYPE 






0361. 


50 41 




LDJ 


K240 






0362 


6 431 




JPS 


TYPE 






0363 


3510 




ISZ 


OCTS 






0364 


6311 




JMP0 


OCTS 


/ 


EXIT 


0365 


0000 


OCT, 











0366 


54 35 




STJ 


TEMP 


t 


STORE J IN TEMP 


0367 


6436 




JPS 


OUT 


/ 


GO TQ OUT 


376i 


6405 




JPS 


OUT 


/ 


u 


0371 


6404 




JPS 


OUT 


/ 


ii 


0372 


6403 




JPS 


OUT 


/ 


ii 


0373 


6306 




JMPf 


OCT 


/ 


EXIT 


0374 


0000 


KV# 







/ 


PRODUCT OF MULTIPLICATION - MSB 


0375 


0000 


OUT, 











0376 


50 25 




LDJ 


TEMP 


/ 


SET J « TEMP 


0377 


1 163 




ROTD 


J 3 


/ 


SHIFT MSB OF DIGIT INTO LSB 


0400 


5423 




STJ 


TEMP 






0401 


2107 




ANDL 


7 


/ 


STRIP OFF BITS 0-8 


0402 


4422 




AD J 


K260 


/ 


ADD ASCII 


0403 


64 10 




JPS 


TYPE 


/ 


OUTPUT DIGIT 


040 4 


6307 




JMPgs 


OUT 


/ 


EXIT 


0405 


0000' 


CRLF t 











40 6 


5012 




LDJ 


K2i5 







8-4 



407 


64(34 




JPS 


T YPF 


/ 
f 


OUTPUT CARRIAGE RFTIIRN 


0410 






L D J 


K212 






0411 


6402 




JPS 


TYPE 


/ 


OUTPUT LINE FEED 


Pi 4 1 ? 


•w* \J \.j W 




JMPl® 


TRLF 


j 

r 


FV T T 

U A J, 1 




pi n n 


T YPF . 










Pt 4 1 4 


7 A 1 3 








i 
f 


PI FAR PRTNT F! Af 1 fl A D 


CI 4 1 5 


7 4 14 




Tns 




j 

f 


TS Fl AG & 1 *> 


041 6 


6101 




JMP 




t 


NO, TRY AGAIN 


0417 


6304 




JMP* 


TYPE 


/ 


YES, EXIT 


P! 420 


0215 


K215. 


215 








04P1 


0JH2 


K 2 1 2 » 


212 








3422 


O?40 




24fl 








0423 


00 00 


TEMP, 











0424 


pi a 6 pi 


K2S0, 


260 








0425 


0210 


ALQOPP, 


LOOP1+1 








/E3645 













8-5 



3 E 1310 






A 


JS 




AJ 


a 


0304 


A L P P 




425 


B 


a 


S3 3 i 


CNTR 


a 


3 [71 R 


COUNT? 


«t 


J V ~ V* 


CRLF 


3 


04$* "5 


ERR 




03^7 


JV 




C383 

r ^ w im y 


K? 1 P 




4 ? J, 


K8 1 5 


.3 


42C* 


K248 


S. 






SS 


0424 


KV 


3 


3374 


LIMIT 


a 


0220 


LOOP 1 




0207 


L00P2 


3 


0205 


LQ0-°3 




0202 


MAXREM 


a 


$277 


MDTEST 


a 


0243 


OCT 




C4 36 5 


QCTS 


« 


0353 


OUT- 




f 3 7 S 


REM 


a 


0302 


SCOPE 


B 


0244 


START 


5 


0200 


TEMP 




0423 


TYPE 


3 


0413 


XI 


a 


0313 


X2 


S 


0311 


X3 


B 


0321 


X4 


S 


0265 


ER 0000 







